<%@ taglib prefix="c" uri="http://java.sun.com/jsp/jstl/core" %>
<%@ page contentType="text/html;charset=UTF-8" language="java" %>

<html lang="en">
<head>
    <title>员工管理</title>
    <%@include file="../common/header.jsp"%>

    <script>
        //全部移动
        function moveAll(srcClass,targetClass) {
            //将左边的源全部移动到右边
            $("." + srcClass + " option").appendTo($("." + targetClass));
        }
        //移动选中
        function moveSelected(srcClass,targetClass) {
            //将选中的角色移动到右边
            $("." + srcClass + " option:selected").appendTo($("." + targetClass));
        }

        //页面加载完之后执行
        $(function () {

            //超管隐藏
            var roleDiv;
            $("#admin").click(function () {
                //如果管理员被勾选
                if(this.checked){
                    //删除对应的复选框(保留其原来的按钮功能)
                    roleDiv = $("#role").detach();
                }else{
                    //否则显示复选框
                    //找到管理员勾选框的最近的div,把复选框放在后面
                    $(this).closest("div").after(roleDiv);
                }
            })

            //如果不是在添加界面(即entity不为空)或者编辑时admin已经被选中
            if(${entity != null && entity.admin}){
                //则勾选框为选中状态
                $("#admin").prop("checked",true);
                //隐藏对应的复选框
                roleDiv = $("#role").detach();
            }

            //员工保存
            //角色复选框提交时id也选定提交
            $("#btn_submit").click(function () {

                //选中的角色
                //对应右边列表的角色option,只有被选中时才会提交id数据
                $(".selfRoles option").prop("selected",true);

                //提交表单
                //提交整个表单,高级查询也会影响
                $("#editForm").submit();
            })

            //角色排重
            //获取右边列表所有的角色信息
            //参数1:右边所有角色option,源数组
            //参数2:每次迭代调用函数
                //item:对应数组的每个元素
                //index为每个元素对应的索引
            //返回值:为每个元素的value值,即对应的id
            var ids = $.map($(".selfRoles option"),function (item,index) {
                //原生对象
                return item.value;
            })

            //遍历左边列表的所有角色信息
            //当左边列表具有右边列表的信息时,则删除左边列表的对象信息
            //参数1:左边列表的所有角色option,源数组
            //参数2:每次迭代调用函数
                //index为每个元素对应的索引
                //item为每个元素
            $.each($(".allRoles option"),function (index,item) {

                //判断左边列表的元素对应的id是否在右边列表中
                //.inArray:判断元素是否在数组中
                if($.inArray(item.value,ids) >= 0){
                    //在的话删除对应数组元素
                    //jQuery对象
                    $(item).remove();
                }
            })
        })
    </script>
</head>
<body>
<!--左侧菜单回显变量设置-->
<c:set var="currentMenu" value="employee"/>
<div class="container " style="margin-top: 20px">
    <%@include file="../common/top.jsp"%>
    <div class="row">
        <div class="col-sm-2">
            <%@include file="../common/menu.jsp"%>
        </div>
        <div class="col-sm-10">
            <div class="row">
                <div class="col-sm-12">
                    <h1 class="page-head-line">员工编辑</h1>
                </div>
            </div>
            <div class="row col-sm-10">
                <form class="form-horizontal" action="/employee/saveOrUpdate" method="post" id="editForm">
                    <input type="hidden" value="${entity.id}" name="id">
                    <div class="form-group" >
                        <label for="name" class="col-sm-2 control-label">用户名：</label>
                        <div class="col-sm-6">
                        <input type="text" class="form-control" id="name" name="name" value="${entity.name}" placeholder="请输入用户名">
                        </div>
                    </div>

                    <!--密码隐藏(在编辑时隐藏)-->
                    <%-- 编辑时,数据不为空,则判断为false,下面密码不显示在页面上--%>
                    <c:if test="${empty entity}">
                    <div class="form-group">
                        <label for="password" class="col-sm-2 control-label">密码：</label>
                        <div class="col-sm-6">
                        <input type="password" class="form-control" id="password"  name="password"  placeholder="请输入密码">
                        </div>
                    </div>
                    <div class="form-group">
                        <label for="repassword" class="col-sm-2 control-label">验证密码：</label>
                        <div class="col-sm-6">
                        <input type="password" class="form-control" id="repassword" placeholder="再输入一遍密码">
                        </div>
                    </div>
                    </c:if>

                    <div class="form-group">
                        <label for="email" class="col-sm-2 control-label">Email：</label>
                        <div class="col-sm-6">
                        <input type="text" class="form-control" id="email" name="email" value="${entity.email}" placeholder="请输入邮箱">
                        </div>
                    </div>
                    <div class="form-group">
                        <label for="age" class="col-sm-2 control-label">年龄：</label>
                        <div class="col-sm-6">
                        <input type="text" class="form-control" id="age" name="age" value="${entity.age}" placeholder="请输入年龄">
                        </div>
                    </div>
                    <!-- 3 部门的回显以及下拉框-->
                    <div class="form-group">
                        <label for="dept" class="col-sm-2 control-label">部门：</label>
                        <div class="col-sm-6">
                        <select class="form-control" id="dept" name="dept.id">
                            <%--根据后端传来的部门列表,显示所有部门名字--%>
                            <c:forEach items="${depts}" var="d">
                                <option value="${d.id}">${d.name}</option>
                            </c:forEach>
                        </select>
                            <script>
                                /*根据后端controller获取来的信息回显部门信息*/
                                $("#dept option[value='${entity.dept.id}']").prop("selected",true);
                            </script>
                        </div>
                    </div>

                    <!-- 2 超级管理员回显和隐藏-->
                    <div class="form-group">
                        <label for="admin" class="col-sm-2 control-label">超级管理员：</label>
                        <label class="checkbox-inline" style="margin-left: 15px;">
                            <input type="checkbox" id="admin" name="admin" >
                        </label>

                    </div>

                    <!-- 1 复选框的隐藏和角色移动-->
                    <div class="form-group" id="role">
                        <div>
                            <label for="role" class="control-label" style="margin-left: 60px">角色：</label>
                        </div>
                        <div class="row" style="margin-top: 10px">
                            <div class="col-sm-4 col-sm-offset-1">
                                <!--左边列表-->
                                <select multiple class="form-control allRoles" size="15">
                                    <%-- 1.1 初始显示所有角色--%>
                                    <c:forEach items="${roles}" var="r">
                                        <option value="${r.id}">${r.name}</option>
                                    </c:forEach>
                                </select>
                            </div>
                            <div class="col-sm-2" style="margin-top: 60px;" align="center">
                                <%-- 1.2 移动方法 --%>
                                <div >
                                    <a type="button" class="btn btn-info  "  style="margin-top: 10px"
                                    onclick="moveSelected('allRoles','selfRoles')">&nbsp;&gt;&nbsp;</a>
                                    <br>
                                    <a type="button" class="btn btn-info " style="margin-top: 10px"
                                    onclick="moveSelected('selfRoles','allRoles')">&nbsp;&lt;&nbsp;</a>
                                    <br>
                                    <a type="button" class="btn btn-info " style="margin-top: 10px"
                                    onclick="moveAll('allRoles','selfRoles')">&gt;&gt;</a>
                                    <br>
                                    <a type="button" class="btn btn-info " style="margin-top: 10px"
                                    onclick="moveAll('selfRoles','allRoles')">&lt;&lt;</a>
                                </div>
                            </div>

                            <div class="col-sm-4">
                                <!--右边列表 在编辑时回显员工所具有的角色信息 需要注意角色选定-->
                                <select multiple class="form-control selfRoles" size="15" name="ids">
                                    <c:forEach items="${entity.roles}" var="role">
                                        <option value="${role.id}">${role.name}</option>
                                    </c:forEach>
                                </select>
                            </div>
                        </div>
                    </div>

                    <div class="form-group">
                        <div class="col-sm-offset-1 col-sm-6">
                            <button id="btn_submit" type="button" class="btn btn-default">保存</button>
                            <button type="reset" class="btn btn-default">重置</button>
                        </div>
                    </div>
                </form>
            </div>
        </div>
    </div>
</div>
</body>
</html>